Claims 

We claim: 

1. A \computer-implemented method for curve fitting, the method 
5 comprising: 

a) receiving ^plurality of data points; 
^ b) generating \ curve based on two or more random points of the plurality of data 

points; 

c) testing the curve against a first subset of the plurality of data points, wherein 
1 0 said testing produces firs\ test results; 

d) if said first test\results meet first criteria, outputting information regarding the 

curve. 

2. The method of claim 1, wherein the method comprises performing (b) and 
15 (c) a plurality of times to detarnine a curve which meets the first criteria. 

3. The method of alaim 2, wherein said performing (b) and (c) a plurality of 
times comprises performing (b\ and (c) in an iterative manner until ending criteria are 
met. 



20 



4. The method of claim 3, wherein said ending criteria comprise one or more 



of: 



the number of iterations meeting or exceeding an iteration threshold; and 
a number of data points of the murality of data points within a specified radius of 
25 the curve meeting or exceeding a specified minimum value. 

5. The method of claim 1, fiiitnter comprising: 

pre-testing the curve against a second subset of the plurality of data points, 
wherein said testing produces second test resultV 
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wheitein, if said second test results meet second criteria, then performing c) and d). 

6. XThe method of claim 5, wherein the second subset is smaller than the first 
subset. \ 

7. Th& method of claim 5, wherein the second subset is a random subset 
comprising randomly selected points from the plurality of data points. 

8. The method of claim 7, further comprising: 

randomizing the plurality of data points after said receiving to generate a 
randomized list of the Plurality of data points; 

wherein said randomly selected points from the plurality of data points are 
selected by traversing the randomized list. 

9. The method of claim 8, wherein said randomizing the plurality of data 
points further comprises selecting a random starting position in the randomized list, and 
wherein said traversing the randomized list comprises traversing the randomized list 
starting at the random starting position. 

10. The method of claim 5, wherein said pre-testing the curve against a second 
subset of the plurality of data points comprises: 

determining a number oflthe second subset of the plurality of data points which 
are within the specified radius of me curve; 

wherein said second test results comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve. 

11. The method of claim M), wherein said second criteria comprise said 
number of the second subset of the plurality of data points which are within the specified 
radius of the curve meeting or exceeding a threshold value. 
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12. Tne method of claim 10, wherein said second criteria comprise said 
number of the secbnd subset of the plurality of data points which are within the specified 
radius of the curve meeting or exceeding a specified fraction of the second subset. 

13. The method of claim 1, wherein said testing the curve against a first subset 
of the plurality of data points comprises: 

determining a number of the first subset of the plurality of data points which are 
within the specified radiusW the curve; 

wherein said first test results comprise said number of the first subset of the 
plurality of data points whicn are within the specified radius of the curve. 

14. The method of claim 13, wherein said first criteria comprise said number 
of the first subset of the plurality of data points which are within the specified radius of 
the curve meeting or exceeding a specified fraction of the first subset. 

15. The method of clam 1, wherein the first subset comprises substantially all 
of the plurality of data points. \ 

16. The method of claim 1, wherein said outputting information comprises 
displaying the generated curve on a Sisplay device. 

17. The method of claim 1, Wherein the curve comprises one of a line, a circle, 
and an ellipse. \ 

18. The method of claim 1 , further comprising: 

performing a refined curve fit, wherein the refined curve fit is performed using a 
second subset of the plurality of data points Vomprising data points within said specified 
radius of the curve, wherein the refined curva fit comprises iteratively culling outlying 
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data points from the second subset, generating a culled subset of data points, and fitting a 
refined cuWe to the culled subset at each iteration until an ending condition is met, 
wherein theVefined curve fit generates a refined curve, and 

generating output, comprising one or more of information regarding the refined 
curve, and theVulled subset of the plurality of data points. 

19. Tlje method of claim 18, wherein said performing a refined curve fit 
comprises: 

calculating \a maximum error allowed for the refined curve fit based on the 
specified radius; 

removing ondor more points from the second subset, wherein said one or more 
points are furthest from curve, thereby generating a culled subset; 
fitting a curve ro the culled subset; 
calculating an ecror for the curve on the culled subset; 

repeating said rmnoving, said fitting, and said calculating one or more times to 
generate a refined curve; land 

generating result output, wherein said result output comprises one or more of: 

the culled subset; 

the refined curve; 

the error fortthe curve on the culled subset; 

a score, indicating the fitness of the refined curve with respect to the 
plurality of points; and 

the plurality ofldata points. 



20. The method of claim 1 , 

wherein the plurality of data points comprises pixels of an image; and 

wherein the curve fitting nrethod operates to perform edge detection on the image. 
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21. VA. computer-implemented method for curve fitting, the method 
comprising: 

a) receiving a plurality of data points; 

b) performing the following steps c) through f) in an iterative manner: 
5 c) generating a curve based on two or more random points of the plurality 

of data points; 

d) pile-testing the curve against a first random subset of the plurality of 
data points, wherein said testing produces first test results; 

e) if said first test results meet first criteria, testing the curve against a 
10 second subset of the plurality of data points, thereby generating second test results; 

f) if sam second test results meet second criteria, storing information 
regarding the curve; anc 

g) outputtinl said information regarding the curve. 

15 22. The methon of claim 2 1 , further comprising: 

randomizing the order of the plurality of data points before said performing to 
produce a randomized list pf the plurality of data points; 

wherein said first random subset is selected by traversing said randomized list. 

20 23. The method ©f claim 22, wherein said randomizing the plurality of data 

points further comprises selecting a random starting position in the randomized list, and 
wherein said traversing the randomized list comprises traversing the randomized list from 
the random starting position. 



25 24. The method of Maim 21, wherein said second subset substantially 

comprises data points which are not in said first subset. 
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25. ^ The method of claim 21, wherein said performing the steps c) through f) in 
an iterative nmnner comprises performing the steps c) through f) in an iterative manner 
until third cnterta are met. 

26. Tha method of claim 25, wherein said third criteria comprise one or more 
of: \ 

the number of iterations meeting or exceeding an iteration threshold; and 
a number of data points of the plurality of data points within a specified radius of 
the curve meeting or exceeding a specified minimum value. 

27. The methfod of claim 21, wherein the first subset is smaller than the second 
subset. \ 

28. The methodlof claim 21, wherein said pre-testing the curve against a first 
subset of the plurality of dam points comprises: 

determining a numblr of the first subset of the plurality of data points which are 
within a specified radius of tne curve; 

wherein said first test results comprise said number of the first subset of the 
plurality of data points which are within the specified radius of the curve. 

29. The method of cl\im 28, wherein said first criteria comprise said number 
of the first subset of the pluralitwof data points which are within the specified radius of 
the curve meeting or exceeding a threshold value. 

30. The method of claim ^28, wherein said first criteria comprise said number 
of the first subset of the plurality of oata points which are within the specified radius of 
the curve meeting or exceeding a specified fraction of the first subset. 
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3 1 . )The method of claim 28, wherein said testing the curve against the second 
subset of the plurality of data points comprises: 

determining a number of the second subset of the plurality of data points which 
are within a specified radius of the curve; 

wherein saidreecond test results comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve. 

32. The method of claim 31, wherein said second criteria comprise said 
number of the second subset of the plurality of data points which are within the specified 
radius of the curve meeting or exceeding a specified fraction of the second subset. 

33. The methodiof claim 31, wherein said second criteria comprise said 
number of the second subsettof the plurality of data points which are within the specified 
radius of the curve plus said number of the first subset of the plurality of data points 
which are within the specified radius of the curve meeting or exceeding a specified 
fraction of the plurality of datatpoints. 

34. The method of olaim 21, wherein said outputting information comprises 
displaying the generated curve on a display device. 

35. The method of claim 21, wherein information regarding the curve 
comprises one or more of: 1 

one or more parameters defining the curve; 

a third subset of the plurality of data points, comprising data points which are 
within a specified radius of the curva 

36. The method of claim 21, wherein the curve comprises one of a line, a 
circle, and an ellipse. \ 
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3tf . The method of claim 2 1 , further comprising: 

performing a refined curve fit, wherein the refined curve fit is performed using a 
third subset of the plurality of data points comprising data points within a specified radius 
of the curve, Wherein performing the refined curve fit comprises iteratively culling 
outlying data pcdnts from the third subset, generating a culled subset of data points, and 
fitting a refined qurve to the culled subset at each iteration until an ending condition is 
met, thereby generating a refined curve, and 

generating output, comprising one or more of information regarding the generated 
refined curve, and the Vulled subset of the plurality of data points. 

38. The method of claim 37, wherein said performing a refined curve fit 
comprises: \ 

calculating a maximum error allowed for the refined curve fit based on the 
specified radius; \ 

fitting a curve to the thfrd subset of data points; 

removing one or more points from the third subset, wherein said one or more 
points are furthest from the curvq thereby generating a culled subset; 
fitting a curve to the culledisubset; 
calculating an error for the cbrve on the culled subset; 

repeating said removing, saik fitting, and said calculating one or more times to 
generate a refined curve; and \ 

generating result output, wherein said result output comprises one or more of: 

the culled subset; \ 

the generated refined curve;\ 

the calculated error for the cutve on the culled subset; 
a score, indicating the fitness of the refined curve with respect to the 
plurality of points; and \ 
the plurality of data points. \ 
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39. Tfee method of claim 21, 
wherein tlife plurality of data points comprises pixels of an image; and 
wherein thelcurve fitting method operates to perform edge detection on the image. 



40. A cqpputer-implemented method for curve fitting, the method 
comprising: 

a) receiving a plurality of data points, P; 

b) randomizing me order of the plurality of data points P; 

c) performing the following steps d) through j) in an iterative manner: 

d) selecting two or more data points from P; 

e) generating a curve using the two or more data points, wherein said 
generating comprises calculating two or more parameters defining the curve; 

f) selecting a subset P m of P, wherein P m comprises M data points; 

g) determii ing and recording a subset Pj of P m , wherein Pj comprises J data 
points in P m whos e distance from the curve is less than or equal to a specified 
radius. 1 

h) if a ratiolof J to M exceeds a threshold, updating the recorded subset Pj 
and J to include all points in P whose distance from the curve is less than or equal 
to the specified radius; 

i) if J exceeds all values of J calculated in previous iterations, recording 
the subset Pj as a subset P^Acomprising J max data points, and recording the two or more 
parameters defining the cur\^, wherein the curve comprises an estimated fit to the 
plurality of data points, P; 

j) testing for criteria to end said iterating; and 

k) generating output, wherein said output comprises the subset P max , and said two 
or more parameters defining the generated curve; 

wherein said criteria comprise\one or more of: 

the number of iterations Vieeting or exceeding an iteration threshold; and 
the value of J max meeting o\exceeding a minimum point count. 
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41. \ The method of claim 40, wherein said at least two points comprise N c data 
points, and whVein said performing a refined curve fit comprises: 

1) calculating a maximum error err^ allowed for the refined curve fit based on the 
specified radius; 

m) setting afo optimal set of data points Kq to P n 
n) fitting an initial curve L 0 to the optimal set of data points K^; 
o) calculating an error err 0 for the initial curve L 0 on K^; 
p) determining if an ending condition is true; 

q) if said endinglcondition is not true, performing the following steps r) through u) 
iteratively, until said endmg condition is true, wherein is a state of the set Ko at each 
iteration i 5 and L { is a corresponding line fitted to K^: 

r) removing^ points from K^, wherein said ? { points are furthest from 
curve L i5 thereby generatingrcubset of K^; 

s) fitting a cuiVe L i+1 to subset K^,; 

t) calculating am error err i+1 for the curve L H1 on subset K^,; 

u) incrementings; 
wherein said ending condition comprises one or more of: 

eiTj meeting or exceeding err max ; and 

a count of being requal to N c ; 
v) calculating a score s fmal oK a final curve L final on a final subset K BnsA9 wherein L fmal 
and subset comprise final statesapf L { and K^, respectively; and 

w) calculating an error err final qf the curve L finaI on the plurality of data points P; 
x) generating result output, whejjrein said result output comprises one or more of: 

the final subset K final ; 

the size of K fmal; 

the curve L fmal ; 

the score s final ; and 

the plurality of data points P. 
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42. V memory medium operable to store program instructions for performing 
a curve fit on aVeceived plurality of data points, wherein the program instructions are 
executable to perf&rm: 

a) generatiire a curve based on two or more random points of the plurality of data 
points; \ 

b) testing theVurve against a first subset of the plurality of data points, wherein 
said testing produces first test results; 

c) if said first test results meet first criteria, outputting information regarding the 
curve. \ 

medium of claim 42, wherein the program instructions are 
tL (a) and (b) a plurality of times to determine a curve which 

44. The memory medium of claim 42, wherein the program instructions are 
further executable to perform: \ 

pre-testing the curve against a second subset of the plurality of data points, 
wherein said testing produces second test results, wherein said second subset is a random 
subset comprising randomly selected points from the plurality of data points; 

wherein, if said second test Kesults meet second criteria, then performing c) and d). 

45. The memory mediunA of claim 44, wherein the program instructions are 
further executable to perform: \ 

randomizing the plurality ofldata points after said receiving to generate a 
randomized list of the plurality of data pbints; 

wherein said randomly selected points from the plurality of data points are 
selected by traversing the randomized listA 



43. The memor 
further executable to perfor 
meets the first criteria. 
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46. \ The memory medium of claim 44, 

wherein said pre-testing the curve against a second subset of the plurality of data 
points comprises determining a number of the second subset of the plurality of data 
points which are within a specified radius of the curve; 

wherein said second test results comprise said number of the second subset of the 
plurality of data poults which are within the specified radius of the curve; 

wherein said second criteria comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve meeting or 
exceeding a thresholdlvalue; 

wherein said testing the curve against a first subset of the plurality of data points 
comprises determiningia number of the first subset of the plurality of data points which 
are within the specified radius of the curve; 

wherein said first test results comprise said number of the first subset of the 
plurality of data points wftich are within the specified radius of the curve; and 

wherein said first criteria comprise said number of the first subset of the plurality 
of data points which are within the specified radius of the curve meeting or exceeding a 
threshold value. ^ 

47. The memory m|dium of claim 42, wherein the program instructions are 
further executable to perform: \ 

performing a refined curw fit, wherein the refined curve fit is performed using a 
second subset of the plurality of data points comprising data points within said specified 
radius of the curve, wherein the refined curve fit comprises iteratively culling outlying 
data points from the second subset, generating a culled subset of data points, and fitting a 
refined curve to the culled subset atleach iteration until an ending condition is met, 
wherein the refined curve fit generates aVefined curve, and 

generating output, comprising one or more of information regarding the refined 
curve, and the culled subset of the pluralitwof data points. 
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48. \ A memory medium operable to store program instructions for performing 
a curve fit on \ received plurality of data points, wherein the program instructions are 
executable to peribrm: 

a) performing the following steps b) through e) in an iterative manner: 
5 b) generating a curve based on two or more random points of the plurality 

of data points; 

c) pretesting the curve against a first random subset of the plurality of 
data points, wherein sara testing produces first test results; 

d) if said first test results meet first criteria, testing the curve against a 
10 second subset of the plurality of data points, thereby generating second test results; 

e) if said second test results meet second criteria, storing information 
regarding the curve; and 

f) outputting sai| information regarding the curve. 

15 49. The memory medium of claim 48, wherein the program instructions are 

further executable to perform: 

randomizing the order 6$ the plurality of data points before said performing to 
produce a randomized list of the plurality of data points; 

wherein said first random subset is selected by traversing said randomized list. 

20 

50. The memory mediunrtof claim 48, 

wherein said pre-testing the c^urve against a first subset of the plurality of data 
points comprises determining a number of the first subset of the plurality of data points 
which are within a specified radius of the curve; 
25 wherein said first test results comprise said number of the first subset of the 

plurality of data points which are within the specified radius of the curve; 

wherein said first criteria comprise said number of the first subset of the plurality 
of data points which are within the specified\radius of the curve meeting or exceeding a 
first threshold value; 
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wherem said testing the curve against the second subset of the plurality of data 
points comprises determining a number of the second subset of the plurality of data 
points which are within the specified radius of the curve; 

wherein saiti second test results comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve; and 

wherein said second criteria comprise said number of the second subset of the 
plurality of data poinls which are within the specified radius of the curve meeting or 
exceeding a second threshold value. 

51. The memory medium of claim 50, wherein said second criteria further 
comprise said number of me second subset of the plurality of data points which are within 
the specified radius of theWrve plus said number of the first subset of the plurality of 
data points which are within the specified radius of the curve meeting or exceeding the 
specified second threshold value. 



52. The memory mpdium of claim 48, wherein the program instructions are 
further executable to perform:: 

performing a refined cui^e fit, wherein the refined curve fit is performed using a 
third subset of the plurality of data points comprising data points within a specified radius 
of the curve, wherein performing the refined curve fit comprises iteratively culling 
outlying data points from the third subset, generating a culled subset of data points, and 
fitting a refined curve to the culled ^bset at each iteration until an ending condition is 
met, thereby generating a refined curv^and 

generating output, comprising one or more of information regarding the generated 
refined curve, and the culled subset of theftplurality of data points. 



53. A computer based system : 
a CPU; 



performing a curve fit, comprising: 
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a memory medium coupled to the CPU, wherein the memory is operable to store 
program instructions, and wherein the CPU is operable to execute the program 
instructions; and 

an input which is operable to receive a plurality of data points; 

wherein\he program instructions are executable by the CPU to perform: 

a) \enerating a curve based on two or more random points of the plurality 

of data points; 

b) testing the curve against a first subset of the plurality of data points, 
wherein said testing produces first test results; 

c) if s^d first test results meet first criteria, outputting information 
regarding the curve. 



54. The systeni of claim 53, wherein the program instructions are further 
executable by the CPU to perform (a) and (b) a plurality of times to determine a curve 
which meets the first criteria! 



55. The system oftelaim 53, wherein the program instructions are further 
executable by the CPU to perforai: 

pre-testing the curve aganst a second subset of the plurality of data points, 
wherein said testing produces second test results, wherein said second subset is a random 
subset comprising randomly selected points from the plurality of data points; 

wherein, if said second test results meet second criteria, then performing c) and d). 



2S^S 



56. The system of claim 5\ wherein the program instructions are further 
executable by the CPU to perform: 

randomizing the plurality of dat^ points after said receiving to generate a 
randomized list of the plurality of data points^ 

wherein said randomly selected poiri^ from the plurality of data points are 
selected by traversing the randomized list. 
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57. \The system of claim 55, 

wherein\aid pre-testing the curve against a second subset of the plurality of data 
points comprises\determining a number of the second subset of the plurality of data 
5 points which are wkhin a specified radius of the curve; 

wherein saidVecond test results comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve; 

wherein said second criteria comprise said number of the second subset of the 
plurality of data points which are within the specified radius of the curve meeting or 
10 exceeding a threshold value; 

wherein said testing the curve against a first subset of the plurality of data points 
comprises determining a number of the first subset of the plurality of data points which 
are within the specified radius of the curve; 

wherein said first tesl results comprise said number of the first subset of the 
15 plurality of data points which are within the specified radius of the curve; and 

wherein said first criteria comprise said number of the first subset of the plurality 
of data points which are within fifie specified radius of the curve meeting or exceeding a 
threshold value. 

20 58. The system of clainrt 53, wherein the program instructions are further 

executable by the CPU to perform: 

performing a refined curve fitVwherein the refined curve fit is performed using a 

second subset of the plurality of data pbints comprising data points within said specified 

radius of the curve, wherein the refinedicurve fit comprises iteratively culling outlying 
25 data points from the second subset, generating a culled subset of data points, and fitting a 

refined curve to the culled subset at eacm iteration until an ending condition is met, 

wherein the refined curve fit generates a refined curve, and 

generating output, comprising one or more of information regarding the refined 

curve, and the culled subset of the plurality of dam points. 



A 
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59. \ A computer based system for performing a curve fit, comprising: 
aCPOL 

a memory medium coupled to the CPU, wherein the memory is operable to store 
program instruSjtions, and wherein the CPU is operable to execute the program 
instructions; and \ 

an input which is operable to receive a plurality of data points; 
wherein the program instructions are executable by the CPU to perform: 

a) performing the following steps b) through e) in an iterative manner: 

V) generating a curve based on two or more random points of the 
plurality of data points; \ 

c) Ypre-testing the curve against a first random subset of the 
plurality of data points, wfterein said testing produces first test results; 

d) in said first test results meet first criteria, testing the curve 
against a second subset of\he plurality of data points, thereby generating second test 
results; \ 

e) if ^id second test results meet second criteria, storing 
information regarding the curv^and 

f) outputting\said information regarding the curve. 

60. The system of claim 59, wherein the program instructions are further 
executable by the CPU to perform: \ 

randomizing the order of theVphirality of data points before said performing to 
produce a randomized list of the pluraliw of data points; 

wherein said first random subset \ selected by traversing said randomized list. 

61 . The system of claim 59, \ 
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/herein said pre-testing the curve against a first subset of the plurality of data 
points comprises determining a number of the first subset of the plurality of data points 
which are within a specified radius of the curve; 

wher&n said first test results comprise said number of the first subset of the 
5 plurality of data points which are within the specified radius of the curve; 

wherein said first criteria comprise said number of the first subset of the plurality 
of data points which are within the specified radius of the curve meeting or exceeding a 
first threshold value 

wherein said\testing the curve against the second subset of the plurality of data 
10 points comprises determining a number of the second subset of the plurality of data 
points which are withimthe specified radius of the curve; 

wherein said second test results comprise said number of the second subset of the 
plurality of data points winch are within the specified radius of the curve; and 

wherein said seconM criteria comprise said number of the second subset of the 
15 plurality of data points whifeh are within the specified radius of the curve meeting or 
exceeding a second threshold Wue. 

62. The system of claim 61, wherein said second criteria further comprise said 
number of the second subset of thAplurality of data points which are within the specified 
20 radius of the curve plus said number of the first subset of the plurality of data points 
which are within the specified radius^of the curve meeting or exceeding the specified 
second threshold value. 



63. The system of claim 59, wherein the program instructions are further 
25 executable by the CPU to perform: 

performing a refined curve fit, whereimthe refined curve fit is performed using a 
third subset of the plurality of data points comprising data points within a specified radius 
of the curve, wherein performing the refined cVve fit comprises iteratively culling 
outlying data points from the third subset, generating^ a culled subset of data points, and 
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fitting a refinfed curve to the culled subset at each iteration until an ending condition is 
met, thereby geWating a refined curve, and 

generatinj^utput, comprising one or more of information regarding the generated 
refined curve, and t^e culled subset of the plurality of data points. 
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